草庐IT

sql - 在go中参数化sql查询

全部标签

sql - SQL 查询的最大长度

SELECTf.*FROMfeedsf,user_feedsufWHERE(f.id=uf.feed_idanduf.user_idin(1,2,5,6,23,45))ORDERBYcreated_atDESC这是用于构建用户提要的查询。这个查询的问题是“uf.user_idin()”随着用户关注的用户数量的增加而增加。SQL查询允许的最大长度是多少?有没有更好的方法来实现上面的查询?注意:我正在使用ActiveRecord和Postgres。 最佳答案 PostgreSQL可以处理的查询的最大长度是2147483648个字符(带符

ruby-on-rails - Rails 4 强参数 : can I 'exclude' /blacklist attributes instead of permit/whitelist?

我正在将Rails3应用程序迁移到Rails4,并且正在将attr_accessible属性转换为Controller中的强参数。APIDocumentation显示如何“允许”属性:defperson_paramsparams.require(:person).permit(:name,:age)end然而,我的绝大多数属性都是批量分配安全的。我只需要将:account_id和:is_admin等几个属性列入黑名单。是否可以将属性列入黑名单而不是将几乎所有属性列入白名单?例如:defuser_paramsparams.require(:user).exclude(:account_i

ruby-on-rails - 如何使用 Ruby 中哈希的查询参数构造 URI

如何通过传递哈希来构造带有查询参数的URI对象?我可以生成查询:URI::HTTPS.build(host:'example.com',query:"a=#{hash[:a]},b=#{[hash:b]}")产生https://example.com?a=argument1&b=argument2但是我认为为许多参数构造查询字符串将不可读且难以维护。我想通过传递哈希来构造查询字符串。就像下面的例子:hash={a:'argument1',b:'argument2'#...dozenmorearguments}URI::HTTPS.build(host:'example.com',que

ruby - 如何强制 Kaminari 始终包含页面参数?

如果Kaminari生成返回首页的链接,则它的URL生成会忽略页面参数。但是,如果省略page参数,则应用程序会选择随机页面。因此,Kaminari的默认行为会阻止以可靠的方式分页回到第一页。我已经解决了这个问题,稍后会在下面发布我的解决方案,但我想为后代发布这个问题,而且我也是Rails的新手,因此我不确定我的解决方案是最好的或最优雅的,我对改进和改进很感兴趣,如果只是为了我自己的自私教化! 最佳答案 Kaminari中实现我们想要改变的行为的代码行在lib/kaminari/helpers/tags.rb中。,在方法Kamina

ruby - 接受参数作为单个对象或对象数组

我有一堆函数接受对象数组,或设计为被视为包含一个对象的数组的单个对象,我正在寻找一种更简洁的方法来实现这一点。基本上,我想知道如何使以下函数中的unless部分更简洁:deffoo(bar_or_bars)unlessbar_or_bars.is_a?(Array)bar_or_bars=[bar_or_bars]endbar_or_bars.each{ |baz|...}end任何帮助将不胜感激!谢谢。 最佳答案 最简单的解决方案是使用内核方法Array:Array(5)#=>[5]Array([1,2,3])#=>[1,2,3]

ruby - 获取 block 参数个数

我需要获取给定block采用的参数数量。例如:foobar(1,2,3){|a,b,c|}deffoobar(x,y,z,&block)#needtoobtainnumberofargumentsinblock#whichwouldbe3inthisexampleend这在1.9主干中是可能的,但在任何官方版本中都不是。我希望是否有任何方法可以做到这一点而无需下载单独的gem/扩展模块。 最佳答案 当你用&实现一个block时,它就变成了一个Proc对象,它有一个arity方法。请注意-如果proc采用*splatarg,它会返回一

ruby-on-rails - 使用传入的参数在 ActiveAdmin 中的模型上按方法过滤

使用Rails4.2.1和ActiveAdmin1.0.0.pre2我有一个有很多人入住的公寓模型。我希望管理员能够查看索引中的公寓是否与作为参数传入的日期重叠。我有一个关于公寓的方法defavailable_during(start_date,end_date)return!self.occupancies.any?{|occ|occ.date_range_overlap(Date.parse(start_date),Date.parse(end_date))}end如果公寓有任何与两个给定日期重叠的入住,则返回true。关于占用的方法date_range_overlap很容易解释。

ruby-on-rails - 具有多态关联的范围和查询

关于如何在Rails中为多态关联编写作用域,我发现的很少,更不用说如何在多态关联上编写查询了。在Rails文档中,我查看了PolymorphicAssociationssection,JoiningTablessection,和Scopessection.我也做了我应得的谷歌搜索。以这个设置为例:classPet所以宠物可以是animal_type“狗”、“猫”或“鸟”。要显示所有表结构:这是我的schema.rb:create_table"birds",force::cascadedo|t|t.datetime"created_at",null:falset.datetime"upd

sql - 在 Rails 中使用连接执行 update_all

在这种情况下,Rails对原始SQL的抽象让我抓狂。在MySQL中我可以这样做:UPDATEFROMtasksAStLEFTJOINprojectsaspONt.project_id=p.idSETt.invoice_id=7WHEREp.organization_id==42ANDt.invoice_idISNULL我如何在Rails3.0.1中使用预先加载来做到这一点?我已经尝试了以下所有方法:Tasks.joins(:project).where('projects.organization_id'=>42,:invoice_id=>nil).update_all(:invoic

ruby - 如何在 Ruby 中为 splat 参数设置默认值

为splat参数设置默认值会产生错误:1.9.3-p374:001>defab,*c=nil1.9.3-p374:002?>endSyntaxError:(irb):1:syntaxerror,unexpected'=',expecting';'or'\n'defab,*c=nil^from/Users/me/.rvm/rubies/ruby-1.9.3-p374/bin/irb:16:in`'我尝试过的一些变体也不起作用:1.9.3-p374:003>defab,*c=[]1.9.3-p374:005>defab,(*c)=nil1.9.3-p374:007>defab,(*c=[]